package cn.edu.scau.cmi.ema.controller.rest;

import org.springframework.stereotype.Controller;

import java.util.List;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
import java.io.IOException;

import com.google.gson.Gson;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;


import cn.edu.scau.cmi.ema.domain.base.CmiPagination;
import cn.edu.scau.cmi.ema.service.base.CmiPsonService;
import cn.edu.scau.cmi.ema.controller.base.CmiEmaController;
import cn.edu.scau.cmi.ema.dao.*;
import cn.edu.scau.cmi.ema.domain.*;
import cn.edu.scau.cmi.ema.service.*;

import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.WebDataBinder;

@Controller("VideoRestController")
public class VideoRestController extends CmiEmaController {

	/**
	 * Create a new Video entity
	 * 
	 */
	@RequestMapping(value = "/newVideo", method = RequestMethod.POST)
	@ResponseBody
	public Object newVideo(@RequestBody Video video) {
		videoService.saveVideo(video);
		return JSONObject.parse(cmiPsonService.toJsonString(videoDAO.findVideoByPrimaryKey(video.getId()), 2));
	}

	@RequestMapping(value = "/restNewVideo", method = RequestMethod.POST)
	@ResponseBody
	public Object restNewVideo(@RequestBody String videoJson) {
		Video video = new Gson().fromJson(videoJson, Video.class);
		appendReferences(video);
		videoService.saveVideo(video);
		return JSONObject.parse(cmiPsonService.toJsonString(videoDAO.findVideoByPrimaryKey(video.getId()), 2));
	}

	@RequestMapping(value = "/saveVideo", method = RequestMethod.PUT)
	@ResponseBody
	public Video saveVideo(@RequestBody Video video) {
		videoService.saveVideo(video);
		return videoDAO.findVideoByPrimaryKey(video.getId());
	}

	@RequestMapping(value = "/restSaveVideo", method = RequestMethod.PUT)
	@ResponseBody
	public Object restSaveVideo(@RequestBody String videoJson) {
		Video video = new Gson().fromJson(videoJson, Video.class);
		appendReferences(video);
		CmiPsonService cmiPsonService = new CmiPsonService();
		videoService.saveVideo(video);
		return JSONObject.parse(cmiPsonService.toJsonString(videoDAO.findVideoByPrimaryKey(video.getId()), 1));
	}

	@RequestMapping(value = "/restDeleteVideo/{videoId}", method = RequestMethod.DELETE)
	@ResponseBody
	public void restDeleteVideo(@PathVariable Integer videoId) {
		Video video = videoDAO.findVideoByPrimaryKey(videoId);
		videoService.deleteVideo(video);
	}

	@RequestMapping(value = "/restConfirmDeleteVideos")
	@ResponseBody
	public Object restConfirmDeleteVideos(@RequestBody Set<Integer> deleteVideosIds) {
		Set<Video> deleteVideos = videoDAO.findVideosByIds(deleteVideosIds);
		Set<Video> referencedVideos = videoService.loadReferenceVideos(deleteVideos);
		deleteVideos.removeAll(referencedVideos);
		JSONObject jsonObject = new JSONObject();
		jsonObject.put("referencedEntitys", referencedVideos);
		jsonObject.put("deleteEntitys", deleteVideos);
		return JSONObject.parse(jsonObject.toJSONString());
	}

	@RequestMapping("/restDeleteVideos")
	@ResponseBody
	public Object restDeleteVideos(@RequestBody Set<Video> deleteVideos) {
		Iterator<Video> iterator = deleteVideos.iterator();
		while (iterator.hasNext()) {
			Video currentVideo = iterator.next();
			videoService.deleteVideo(currentVideo);
		}
		JSONObject jsonObject = new JSONObject();
		jsonObject.put("url", "listVideos");
		return JSONObject.parse(jsonObject.toJSONString());
	}
	// loadself

	@RequestMapping(value = "/restLoadVideo/{videoId}", method = RequestMethod.POST)
	@ResponseBody
	public Object restLoadVideo(@PathVariable Integer videoId, @RequestBody CmiPagination cmiPagination) {
		CmiPsonService cmiPsonService = new CmiPsonService();
		return JSONObject.parse(cmiPsonService.toPsonString(videoDAO.findVideoByPrimaryKey(videoId), 2, cmiPagination));
	}

	@RequestMapping(value = "/restLoadVideoEvent/{videoId}/event", method = RequestMethod.POST)
	@ResponseBody
	public Object restLoadVideoEvent(@PathVariable Integer videoId, @RequestBody CmiPagination cmiPagination) {
		CmiPsonService cmiPsonService = new CmiPsonService();
		return JSONObject
				.parse(cmiPsonService.toPsonString(videoDAO.findVideoByPrimaryKey(videoId).getEvent(), 2, cmiPagination));
	}

	@RequestMapping(value = "/restLoadVideoFood/{videoId}/food", method = RequestMethod.POST)
	@ResponseBody
	public Object restLoadVideoFood(@PathVariable Integer videoId, @RequestBody CmiPagination cmiPagination) {
		CmiPsonService cmiPsonService = new CmiPsonService();
		return JSONObject
				.parse(cmiPsonService.toPsonString(videoDAO.findVideoByPrimaryKey(videoId).getFood(), 2, cmiPagination));
	}
	// loadReferenceds
	// TODO loadReferencedsPson，这个方法有一些问题，待修复

	public void appendReferences(Video video) {

		Event event = video.getEvent();
		if (event != null)
			video.setEvent(eventService.findEventByPrimaryKey(event.getId()));

		Food food = video.getFood();
		if (food != null)
			video.setFood(foodService.findFoodByPrimaryKey(food.getId()));

	}

	@RequestMapping(value = "/restGetVideoEvent/{videoId}/event", method = RequestMethod.POST)
	@ResponseBody
	public Object restGetVideoEvent(@PathVariable Integer videoId, @RequestBody CmiPagination cmiPagination) {
		CmiPsonService cmiPsonService = new CmiPsonService();
		return JSONObject
				.parse(cmiPsonService.toPsonString(videoDAO.findVideoByPrimaryKey(videoId).getEvent(), 2, cmiPagination));
	}

	@RequestMapping(value = "/restGetVideoFood/{videoId}/food", method = RequestMethod.POST)
	@ResponseBody
	public Object restGetVideoFood(@PathVariable Integer videoId, @RequestBody CmiPagination cmiPagination) {
		CmiPsonService cmiPsonService = new CmiPsonService();
		return JSONObject
				.parse(cmiPsonService.toPsonString(videoDAO.findVideoByPrimaryKey(videoId).getFood(), 2, cmiPagination));
	}

	@RequestMapping(value = "/restListVideos", method = RequestMethod.GET)
	@ResponseBody
	public Object restListVideos() {
		return JSONObject.parse(cmiPsonService.toJsonString(videoService.loadVideos(), 2));
	}

	@RequestMapping(value = "/restListVideosPost", method = RequestMethod.POST)
	@ResponseBody
	public Object restListVideosPost(@RequestBody CmiPagination cmiPagination) {

		CmiPsonService cmiPsonService = new CmiPsonService();
		cmiPagination = videoPaginationService.updateAppPagination(cmiPagination);
		int startResult = (cmiPagination.getCurrentPagination() - 1) * cmiPagination.getPaginationSize();

		Set<Video> videos = videoDAO.findAllVideos(startResult, cmiPagination.getPaginationSize());
		String videoString = cmiPsonService.toPsonString(videos, 2, cmiPagination);

		return JSONObject.parse(videoString);
	}

	@RequestMapping("/videoSelectBox")
	@ResponseBody
	public JSONObject videoSelectBox(@RequestParam(required = false) String searchTable,
			@RequestParam(required = false) Set<Integer> searchValue, // 杨宏宇2019-9-10：searchValue是在selectpage.js的616行定义，如果要修改searchValue的名称，1.可以修改在selectpage.js修改；2.可以
																		// @RequestParam(value="searchValue", required =
																		// false) Set<Integer> someName
			@RequestParam(required = false, defaultValue = "10") int paginationSize,
			@RequestParam(required = false, defaultValue = "1") int pageNumber,
			@RequestParam(value = "qWord[]", required = false) String queryword,
			@RequestParam(required = false) String selectItem) throws IOException {
		Set entitySet = null;
		Integer count = 0;

		// 初始化原始值

		if (searchValue != null) {
			switch (searchTable) {
			// 外键
			case "Event":
				entitySet = eventService.loadEventsByIdSet(searchValue);
				break;
			case "Food":
				entitySet = foodService.loadFoodsByIdSet(searchValue);
				break;

			// 被引用键
			}
			// 没有测试，深度需要多少？？？
			String jsonData = cmiPsonService.toJsonString(entitySet, 1);
			JSONArray jsonArray = new JSONArray();
			jsonArray = (JSONArray) JSON.parse((String) jsonData);

			JSONObject jsonObject = new JSONObject();
			jsonObject.put("list", jsonArray);
			jsonObject.put("totalRow", entitySet.size());
			return jsonObject;
		}

		// 不根据关键字进行搜索
		if (queryword == null || queryword.trim() == "") {
			switch (selectItem) {
			// 外键
			case "Event":
				entitySet = eventDAO.findAllEvents((pageNumber - 1) * paginationSize, paginationSize);
				count = eventService.countEvents();
				break;
			case "Food":
				entitySet = foodDAO.findAllFoods((pageNumber - 1) * paginationSize, paginationSize);
				count = foodService.countFoods();
				break;

			// 被引用键
			}
		} else {
			switch (selectItem) {
			// 外键
			case "Event":
				entitySet = eventDAO.findEventByNameContaining(queryword, (pageNumber - 1) * paginationSize,
						paginationSize);
				count = eventService.countEventsByName(queryword);
				break;
			case "Food":
				entitySet = foodDAO.findFoodByNameContaining(queryword, (pageNumber - 1) * paginationSize,
						paginationSize);
				count = foodService.countFoodsByName(queryword);
				break;

			// 被引用键
			}
		}
		/**
		 * 将Json数据转换成jsonArray形式，需要通过pson方式进行转换，然后再转换成JsonArray。因为存在懒加载
		 * 没有直接使用CmiPsonService中的fromJson方法是因为，fromJson方法会将int类型的直接转换成double类型的数据，这个问题还没有解决
		 */
		// 没有测试，深度需要多少？？？
		String jsonData = cmiPsonService.toJsonString(entitySet, 1);
		JSONArray jsonArray = new JSONArray();
		jsonArray = (JSONArray) JSON.parse((String) jsonData);

		JSONObject jsonObject = new JSONObject();
		jsonObject.put("list", jsonArray);
		jsonObject.put("paginationSize", paginationSize);
		jsonObject.put("pageNumber", pageNumber);
		jsonObject.put("totalRow", count);
		jsonObject.put("totalPaginations",
				count % paginationSize == 0 ? count / paginationSize : count / paginationSize + 1);
		return jsonObject;
	}
}
